public class Solution {
private static final Map<Character, Integer> map = new HashMap<Character, Integer>();
static {
map.put('I', 1);
map.put('V', 5);
map.put('X', 10);
map.put('L', 50);
map.put('C', 100);
map.put('D', 500);
map.put('M', 1000);
}
public int romanToInt(String s) {
return romanToIntSelf(s, 0, s.length());
}
private int romanToIntSelf(String s, int start, int end) {
if (start >= end) return 0;
int result = 0;
int maxIndex = findMaxIndex(s, start, end);
char max = s.charAt(maxIndex);
result += map.get(max);
result += romanToIntSelf(s, maxIndex + 1, end);
result -= romanToIntSelf(s, start, maxIndex);
return result;
}
* 找到字符串中表示最大的罗马数字支付串所在的位置
*
* @param s
* @param start inclusive
* @param end exclusive
*/
private int findMaxIndex(String s, int start, int end) {
char temp = s.charAt(start);
int result = start;
for (int i = start + 1; i < end; i++) {
if (bigger(s.charAt(i), temp)) {
result = i;
temp = s.charAt(i);
}
}
return result;
}
* is c1 in romandigit bigger than c2
*
* @return
*/
private boolean bigger(char c1, char c2) {
return map.get(c1) > map.get(c2);
}
class RomanDigit implements Comparable<RomanDigit> {
public RomanDigit() {
}
@Override
public int compareTo(RomanDigit r) {
return 0;
}
}
public static void main(String[] args) {
Solution solution = new Solution();
String s = "XCIX";
System.out.println(solution.findMaxIndex(s, 0, s.length()));
System.out.println(solution.romanToInt(s));
}
}